package com.tang.algorithm.binarySerch;

/**
 * 实现 int sqrt(int x) 函数。
 *
 * 计算并返回 x 的平方根，其中 x 是非负整数。
 *
 * 由于返回类型是整数，结果只保留整数的部分，小数部分将被舍去。
 */
public class SquareRoot {
    public static void main(String[] args) {
        System.out.println(mySqrt(100));
    }
    public static int mySqrt(int x) {
        long left=0;
        long right=x;
        while(left<right){
            // 无符号右移一位 取中位数
            long mid=(left+right+1)>>>1;
            long result = mid*mid;
            if(result>x){
                right = mid-1;
            }else {
                left =mid;
            }
        }
        return (int)left;
    }
}
